草庐IT

xml - Scala XML.loadString 与文字表达式

全部标签

ruby - 如何在 Nokogiri 中使用正则表达式搜索匹配特定开头的文本?

给定:require'rubygems'require'nokogiri'value=Nokogiri::HTML.parse(AFooBCBarDEF"HTML_END我想做一些我可以在Hpricot中做的事情:divs=value.search('//div[@id^="para-"]')如何对XPath样式的元素进行模式搜索?我在哪里可以找到对我有帮助的文档?我没有在rdoc中看到这个。 最佳答案 使用xpath函数starts-with:value.xpath('//p[starts-with(@id,"para-")]')

ruby - 另一种方法而不是转义正则表达式模式?

通常当我的正则表达式模式看起来像这样时:http://www.microsoft.com/然后我必须像这样逃避它:string.match(/http:\/\/www\.microsoft\.com\//)有没有其他方法而不是像那样转义它?我希望能够像这样使用它http://www.microsoft.com,因为我不想转义所有模式中的所有特殊字符。 最佳答案 Regexp.new(Regexp.quote('http://www.microsoft.com/'))Regexp.quote简单地转义任何具有特殊正则表达式含义的字符;

ruby - 是否保证 Ruby 哈希文字的顺序?

Ruby,从v1.9开始,在遍历散列时支持确定性顺序;首先添加的条目将首先返回。这是否适用于文字,即{a:1,b:2}总是在b之前产生a?我用Ruby2.1(MRI)做了一个快速实验,它实际上是一致的,但是语言在多大程度上保证这适用于所有Ruby实现? 最佳答案 有几个位置可以指定,即一些被认为是“Ruby语言规范”的东西:theISORubyLanguageSpecificationtheRubySpecprojecttheYARVtestsuiteTheRubyProgrammingLanguagebookbymatzandDa

ruby - 具有命名捕获组的正则表达式在 Ruby 中获取所有匹配项

我有一个字符串:s="123--abc,123--abc,123--abc"我尝试使用Ruby1.9的新功能“命名组”来获取所有命名组信息:/(?\d*)--(?\s*)/是否有像Python的findall那样返回matchdata集合的API?在这种情况下,我需要返回两个匹配项,因为123和abc重复两次。每个匹配数据都包含每个命名捕获信息的详细信息,因此我可以使用m['number']获取匹配值。 最佳答案 命名捕获只适用于一个匹配结果。Ruby的findall类比是String#scan.您可以使用scan结果作为数组,或将

ruby 正则表达式 : match and get position(s) of

我想匹配一个正则表达式并获取匹配字符串中的位置例如,"AustinTexasDallasTexas".match_with_posn/(Texas)/我想要match_with_posn返回类似:[6,17]其中6和17是单词Texas的两个实例的起始位置。有这样的吗? 最佳答案 使用Ruby1.8.6+,你可以这样做:require'enumerator'#Onlyfor1.8.6,newerversionsshouldnotneedthis.s="AustinTexasDallasTexas"positions=s.enum_f

ruby - 更喜欢 %w(...) 而不是文字数组?

按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭10年前。在向RubyMine输入一个简单的字符串文字数组时:cols=["Col1","Col2"]RubyMine提示我应该更喜欢使用%w而不是文字数组:cols=%w(Col1Col2)它提供了一个指向Ruby风格指南(here)的链接,其中说:Prefer%wtotheliteralarraysyntaxwhenyouneedanarrayofstring

ruby - Ruby 正则表达式中的 '?-mix' 是什么

只是想调试ruby​​中的正则表达式。当我打印正则表达式的内容时,它会在正则表达式的开头显示?-mix,即使这些字符不是表达式的一部分。请查看以下IRB输出以查看此说明irb(main):028:0*EXPR=/^a$/=>/^a$/irb(main):029:0>EXPR=>/^a$/irb(main):030:0>putsEXPR(?-mix:^a$)=>nil可以看到,当你使用puts打印出一个正则表达式的内容时,开头是?-mix。我应该为此担心吗?它来自哪里? 最佳答案 mix不是英文单词mix,而是Regexp的选项。参见

ruby-on-rails - 为什么Ruby的正则表达式使用\A和\z而不是^和$?

我不是Ruby程序员,但当我阅读广泛的RubyonRailssecurityguide,我注意到了这一部分:AcommonpitfallinRuby’sregularexpressionsistomatchthestring’sbeginningandendby^and$,insteadof\Aand\z.有谁知道这只是美学问题还是其他问题?我问是因为我只使用过使用^和$的语言。 最佳答案 这不是Ruby特有的;\A和\Z与^和$不同。^和$是lineanchor的开始和结束,而\A和\Z是stringanchor的开始和结束。Ru

ruby - 如何使用一行正则表达式来获取匹配的内容

我是ruby​​的新手,我想知道我是否可以只用一行来完成这项工作。以本站的“搜索”为例。当用户键入[ruby]regex时,我可以使用以下代码获取标签和关键字'[ruby]regex'=~/\[(.*?)\](.*)/tag,keyword=$1,$2我们可以只写一行吗?更新非常感谢!我可以让它更难更有趣吗,输入可能包含多个标签,例如:[ruby][regex][rails]oneline是否可以使用一行代码获取标签数组和关键字?我试过了,但失败了。 最佳答案 您需要Regexp#match方法。如果您编写/\[(.*?)\](.*

ruby-on-rails - 转义正则表达式中的特殊字符?

我有一个表单,它将文本字段的内容发送到我的Rails应用程序,并且我必须生成这个字符串的正则表达式。我试过这样的:regex=/#{params[:text]}/一般情况下可以,但如果字符串中包含括号或特殊字符,则此方法无效。我不希望Rails处理字符。它们应该自动转义。我试过这样的:/\Q#{params[:text]}\E/但这也不起作用。 最佳答案 你应该使用Regexp.escaperegex=/#{Regexp.escape(params[:text])}/#inrailsmodels/controllerswithmon